# Akdeniz University Computer Engineering Department

CSE206 Computer Organization Week11: Digital Logic

Assoc.Prof.Dr. Taner Danışman tdanisman@akdeniz.edu.tr

|   | Week 1  | 19-Feb-24 Introduction                                                       | Ch1         |
|---|---------|------------------------------------------------------------------------------|-------------|
|   | Week 2  | 26-Feb-24 Computer Evolution                                                 | Ch2         |
|   | Week 3  | 4-Mar-24 Computer Systems                                                    | Ch3         |
|   | Week 4  | 11-Mar-24 Cache Memory, Direct Cache Mapping                                 | Ch4         |
|   | Week 5  | 18-Mar-24 Associative and Set Associative Mapping                            | Ch4         |
|   | Week 6  | 25-Mar-24 Internal Memory, External Memory, I/O                              | Ch5-Ch6-Ch7 |
|   | Week 7  | 1-Apr-24 Number Systems, Computer Arithmetic                                 | Ch9-Ch10    |
| / | Week 8  | 8-Apr-24 Holiday                                                             |             |
|   | Week 9  | 15-Apr-24 Number Systems, Computer Arithmetic                                | Ch11        |
|   | Week 10 | 26-Apr-24 <mark>Midterm</mark>                                               | Ch1-Ch11    |
| / | Week 11 | 29-Apr-24 Digital Logic                                                      | Ch11        |
|   | Week 12 | 6-May-24 Instruction Sets                                                    | Ch12        |
|   | Week 13 | 13-May-24 Addressing Modes                                                   | Ch13        |
|   | Week 14 | 20-May-24 Processor Structure and Function                                   | Ch14        |
|   | Week 15 | 27-May-24 Assembly Language (TextBook: Assembly Language for x86 Processors) | Kip Irvine  |

### Boolean Algebra

- Mathematical discipline used to design and analyze the behavior of the digital circuitry in digital computers and other digital systems
- Named after George Boole
  - English mathematician
  - Proposed basic principles of the algebra in 1854
- Claude Shannon suggested Boolean algebra could be used to solve problems in relay-switching circuit design
- Is a convenient tool:
  - Analysis
    - It is an economical way of describing the function of digital circuitry
  - Design
    - Given a desired function, Boolean algebra can be applied to develop a simplified implementation of that function

### Boolean Variables and Operations

- Makes use of variables and operations
  - Are logical
  - A variable may take on the value 1 (TRUE) or 0 (FALSE).
  - Basic logical operations are AND, OR, and NOT

#### AND

- Yields true (binary value 1) if and only if both of its operands are true
- In the absence of parentheses the AND operation takes precedence over the OR operation
- When no ambiguity will occur the AND operation is represented by simple concatenation instead of the dot operator
- OR
  - Yields true if either or both of its operands are true
- NOT

- lavorta tla a valua of ita ala arana

# Table 11.1 Boolean Operators

| P | Q | $ \begin{array}{c} \mathbf{NOT} \mathbf{P} \\ (\overline{P}) \end{array} $ | <b>P AND Q</b> ( <b>P • Q</b> ) | <b>P OR Q</b> (P+Q) | $\begin{array}{c} \mathbf{P}  \mathbf{N} \mathbf{A} \mathbf{N} \mathbf{D}  \mathbf{Q} \\ (\overline{\mathbf{P} \bullet \mathbf{Q}}  ) \end{array}$ | $\frac{P \text{ NOR } Q}{(\overline{P} + \overline{Q})}$ | <b>P XOR Q</b> ( P ⊕ Q) |
|---|---|----------------------------------------------------------------------------|---------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------|-------------------------|
| 0 | 0 | 1                                                                          | 0                               | 0                   | 1                                                                                                                                                  | 1                                                        | 0                       |
| 0 | 1 | 1                                                                          | 0                               | 1                   | 1                                                                                                                                                  | 0                                                        | 1                       |
| 1 | 0 | 0                                                                          | 0                               | 1                   | 1                                                                                                                                                  | 0                                                        | 1                       |
| 1 | 1 | 0                                                                          | 1                               | 1                   | 0                                                                                                                                                  | 0                                                        | 0                       |

(a) Boolean Operators of Two Input Variables

| Operation | Expression            | Output = 1 if                                   |
|-----------|-----------------------|-------------------------------------------------|
| AND       | A • B •               | All of the set $\{A, B,\}$ are 1.               |
| OR        | A + B +               | Any of the set $\{A, B,\}$ are 1.               |
| NAND      | <b>A</b> • <b>B</b> • | Any of the set $\{A, B,\}$ are 0.               |
| NOR       | A+B+                  | All of the set $\{A, B,\}$ are $0$ .            |
| XOR       | A ⊕ B ⊕               | The set {A, B,} contains an odd number of ones. |

(b) Boolean Operators Extended to More than Two Inputs (A, B, . . .)

 $\overline{A \cdot B} = \overline{A} + \overline{B}$ 

# Table 11.2 Basic Identities of Boolean Algebra

|   |                                                                                                           | Basic Postulates                                                                                             |                   |
|---|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------|
|   | $A \cdot B = B \cdot A$                                                                                   | A + B = B + A                                                                                                | Commutative Laws  |
|   | $A \bullet (B + C) = (A \bullet B) + (A \bullet C)$                                                       | $\mathbf{A} + (\mathbf{B} \bullet \mathbf{C}) = (\mathbf{A} + \mathbf{B}) \bullet (\mathbf{A} + \mathbf{C})$ | Distributive Laws |
|   | 1 • A = A                                                                                                 | 0 + A = A                                                                                                    | Identity Elements |
|   | $A \cdot \overline{A} = 0$                                                                                | $A + \overline{A} = 1$                                                                                       | Inverse Elements  |
| • |                                                                                                           | Other Identities                                                                                             |                   |
|   | 0 • A = 0                                                                                                 | 1 + A = 1                                                                                                    |                   |
|   | $A \cdot A = A$                                                                                           | A + A = A                                                                                                    |                   |
|   | $\mathbf{A} \bullet (\mathbf{B} \bullet \mathbf{C}) = (\mathbf{A} \bullet \mathbf{B}) \bullet \mathbf{C}$ | A + (B + C) = (A + B) + C                                                                                    | Associative Laws  |

DeMorgan's Theorem

Table 11.2 Basic Identities of Boolean Algebra

 $\overline{A + B} = \overline{A} \cdot \overline{B}$ 

# Basic Logic Gates Name Graphical Symbol

| 7 Basic Logic Gales | Name | Graphical Symbol      | Algebraic<br>Function     | Truth Table                               |
|---------------------|------|-----------------------|---------------------------|-------------------------------------------|
|                     | AND  | AB—F                  | F = A • B<br>or<br>F = AB | A B F<br>0 0 0<br>0 1 0<br>1 0 0<br>1 1 1 |
|                     | OR   | $A \longrightarrow F$ | F = A + B                 | A B F<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 1 |
|                     | NOT  | A———F                 | F = A'                    | A F<br>0 1<br>1 0                         |
|                     | NAND | A DO-F                | $F = \overline{AB}$       | A B F<br>0 0 1<br>0 1 1<br>1 0 1<br>1 1 0 |
|                     | NOR  | $A \longrightarrow F$ | $F = \overline{A + B}$    | A B F<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 0 |
|                     | XOR  | $A \longrightarrow F$ | F = A⊕B                   | A B F<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 0 |

Algebraic





Figure 11.2 Some Uses of NAND Gates





Figure 11.3 Some Uses of NOR Gates

#### Combinational Circuit

- An interconnected set of gates whose output at any time is a function only of the input at that time
- The appearance of the input is followed almost immediately by the appearance of the output, with only gate delays
- Consists of n binary inputs and m binary outputs
- Can be defined in three ways:
  - Truth table
    - ► For each of the 2<sup>n</sup> possible combinations of input signals, the binary value of each of the *m* output signals is listed
  - Graphical symbols
    - The interconnected layout of gates is depicted
  - Boolean equations
    - Each output signal is expressed as a Boolean function of its input signals

# Boolean Function of Three Variables

There are three combinations of input values that cause F to be 1, and if any one of these combinations occurs, the result is 1. This form of expression, for self- evident reasons, is known as the **sum of products (SOP)** form.

| A | В | С | F |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 1 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 0 |

Table 11.3 A Boolean Function of Three Variables

#### Product-of-Sums Implementation of Table 11.3



Figure 11.5 Product-of-Sums Implementation of Table 11.3

# Algebraic Simplification



Figure 11.6 Simplified Implementation of Table 11.3

• Involves the application of the identities of Table 11.2 to reduce the Boolean expression to one with fewer elements

### Karnaugh Maps

A convenient way of representing a Boolean function of a small number (up to four) of variables



Figure 11.7 The Use of Karnaugh Maps to Represent Boolean Functions



Figure 11.8 Example Use of Karnaugh Maps





Figure 11.9 Overlapping Groups

#### Truth Table for the One-Digit Packed Decimal Incrementer

| 1                |         |   | In | out |   |        |   | Out | put |   |
|------------------|---------|---|----|-----|---|--------|---|-----|-----|---|
|                  | Number  | A | В  | С   | D | Number | W | X   | Y   | Z |
|                  | 0       | 0 | 0  | 0   | 0 | 1      | 0 | 0   | 0   | 1 |
|                  | 1       | 0 | 0  | 0   | 1 | 2      | 0 | 0   | 1   | 0 |
|                  | 2       | 0 | 0  | 1   | 0 | 3      | 0 | 0   | 1   | 1 |
|                  | 3       | 0 | 0  | 1   | 1 | 4      | 0 | 1   | 0   | 0 |
|                  | 4       | 0 | 1  | 0   | 0 | 5      | 0 | 1   | 0   | 1 |
|                  | 5       | 0 | 1  | 0   | 1 | 6      | 0 | 1   | 1   | 0 |
|                  | 6       | 0 | 1  | 1   | 0 | 7      | 0 | 1   | 1   | 1 |
| $\setminus \mid$ | 7 /     | 0 | 1  | 1   | 1 | 8      | 1 | 0   | 0   | 0 |
| <b>\</b>         | 8/      | 1 | 0  | 0   | 0 | 9      | 1 | 0   | 0   | 1 |
| M                | /9      | 1 | 0  | 0   | 1 | 0      | 0 | 0   | 0   | 0 |
| \ \              |         | 1 | 0  | 1   | 0 |        | d | d   | d   | d |
| \ <b>\</b>       |         |   | 0  | 1   | 1 |        | d | d   | d   | d |
|                  | Don't/  |   | 1  | 0   | 0 |        | d | d   | d   | d |
| \ \ <b>\</b>     | care -  | 1 | 1  | 0   | 1 |        | d | d   | d   | d |
| \ <b>\\</b>      | con-    | 1 | 1  | 1   | 0 |        | d | d   | d   | d |
|                  | dition  | 1 | 1  | 1   | 1 |        | d | d   | d   | d |
|                  | Man Han |   |    |     |   |        |   |     |     |   |
|                  | W       |   |    |     |   |        |   |     |     |   |

Table 11.4 Truth Table for the One-Digit Packed Decimal Incrementer







CD

00 01 111 10

Figure 11.10 Karnaugh Maps for the Incrementer

#### NAND and NOR Implementations

- It is sometimes desirable to implement a Boolean function solely with NAND gates or solely with NOR gates.
- Although this may not be the minimum-gate implementation, it has the advantage of **regularity**, which can simplify the manufacturing process.



Figure 11.11 NAND Implementation of Table 11.3

#### Multiplexers

- Connect multiple inputs to a single output
- At any time, one of the inputs is selected to be passed to the output.
- To select one of the four possible inputs, a 2-bit selection code is needed, and this is implemented as two select lines labeled \$1 and \$2.



Figure 11.12 4-to-1 Multiplexer Representation

# 4-to-1 Multiplexer Truth Table

| S2 | <b>S</b> 1 | F  |
|----|------------|----|
| 0  | 0          | D0 |
| 0  | 1          | D1 |
| 1  | 0          | D2 |
| 1  | 1          | D3 |

Table 11.7 4-to-1 Multiplexer Truth Table

#### Decoders

 Combinational circuits with a number of output lines, only one of which is asserted at any time



Figure 11.15 Decoder with 3 Inputs and  $2^3 = 8$  Outputs

### Address Decoding



1K-byte memory using four 256 \* 8-bit RAM chips

Figure 11.16 Address Decoding

# Read-Only Memory (ROM)

- Memory that is implemented with combinational circuits
  - Combinational circuits are often referred to as "memoryless" circuits because their output depends only on their current input and no history of prior inputs is retained
- Memory unit that performs only the read operation
  - Binary information stored in a ROM is permanent and is created during the fabrication process
  - A given input to the ROM (address lines) always produces the same output (data lines)
  - Because the outputs are a function only of the present inputs, ROM is a combinational circuit

# Binary Addition Truth Tables

|   | (a) Single- | Bit Addition | 1     |
|---|-------------|--------------|-------|
| A | В           | Sum          | Carry |
| 0 | 0           | 0            | 0     |
| 0 | 1           | 1            | 0     |
| 1 | 0           | 1            | 0     |
| 1 | 1           | 0            | 1     |

|          | (b) Addition with Carry Input |   |     |           |  |  |
|----------|-------------------------------|---|-----|-----------|--|--|
| $C_{in}$ | A                             | В | Sum | $C_{out}$ |  |  |
| 0        | 0                             | 0 | 0   | 0         |  |  |
| 0        | 0                             | 1 | 1   | 0         |  |  |
| 0        | 1                             | 0 | 1   | 0         |  |  |
| 0        | 1                             | 1 | 0   | 1         |  |  |
| 1        | 0                             | 0 | 1   | 0         |  |  |
| 1        | 0                             | 1 | 0   | 1         |  |  |
| 1        | 1                             | 0 | 0   | 1         |  |  |
| 1        | 1                             | 1 | 1   | 1         |  |  |

Table 11.9 Binary Addition Truth Tables



Figure 11.19 4-Bit Adder

Implementation of an Adder



Figure 11.20 Implementation of an Adder



Figure 11.21 Construction of a 32-Bit Adder Using 8-Bit Adders

Circuit

Current output depends not only on the current input, but also on the past history of inputs

Makes use of combinational circuits

### Flip-Flops

- Simplest form of sequential circuit
- There are a variety of flip-flops, all of which share two properties:

- 1. The flip-flop is a bistable device. It exists in one of two states and, in the absence of input, remains in that state. Thus, the flip-flop can function as a 1-bit memory.
- 2. The flip-flop has two outputs, which are always the complements of each other.



Figure 11.22 The S-R Latch Implemented with NOR Gates

# NOR S-R Latch Timing Diagram





Figure 11.22 The S-R Latch Implemented with NOR Gates

Figure 11.23 NOR S-R Latch Timing Diagram







# Basic Flip Flops



| Name | Graphical Symbol | Truth Table                                                           |
|------|------------------|-----------------------------------------------------------------------|
| S-R  | S Q              | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                 |
| J–K  | J Q              | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                 |
| D    | D Q              | $\begin{array}{c c} D & Q_{n+1} \\ \hline 0 & 0 \\ 1 & 1 \end{array}$ |

Figure 11.27 Basic Flip-Flops

# Parallel Register





#### Counter

- A register whose value is easily incremented by 1 modulo the capacity of the register
- After the maximum value is achieved the next increment sets the counter value to 0
- An example of a counter in the CPU is the program counter
- Can be designated as:
  - Asynchronous
    - Relatively slow because the output of one flip-flop triggers a change in the status of the next flip-flop
  - Synchronous
    - All of the flip-flops change state at the same time
    - Because it is faster it is the kind used in CPUs

